
# find the account id for a given account
swauth-list -A http://localhost:8080/auth/ -K swauthkey groupX | python -m json.tool

# Find location of files for a given object
swift-get-nodes /etc/swift/object.ring.gz <id> testcontainer test.txt

# Use the given ssh commands to observe the file data on non-handoff nodes
ssh <primarynode> "ls -lah /srv/node/sda6/objects/6075/<.....>"

# View the xattrs for the file
sudo xattr -l <filename>

# observe that the file is *NOT* there on a handoff node
ssh <handoffnode> "ls -lah /srv/node/sda6/objects/<.....>"

# unmount a drive on a non-handoff node
ssh <host> sudo umount /srv/node/sda6

# wait... wait... wait...

# observe that the file has moved (by itself!) to the handoff node
ssh <handoffnode> "ls -lah /srv/node/sda6/objects/<.....>"

# remount the drive
ssh <host> sudo mount /srv/node/sda6

# wait... wait... wait...

# observe that the file has removed itself from the handoff node
ssh <handoffnode> "ls -lah /srv/node/sda6/objects/<.....>"

#
# Now, let's actively pull a drive out of the ring
#

# show all devices
cd /etc/swift
sudo swift-ring-builder object.builder

# find a non-handoff device
sudo swift-ring-builder object.builder search <ip>/sda6

# if that's the right device, remove it
sudo swift-ring-builder object.builder remove <ip>/sda6
sudo swift-ring-builder account.builder remove <ip>/sda6
sudo swift-ring-builder container.builder remove <ip>/sda6

# rebalance the rings
sudo swift-ring-builder object.builder rebalance
sudo swift-ring-builder account.builder rebalance
sudo swift-ring-builder container.builder rebalance

# check what moved
swift-get-nodes /etc/swift/object.ring.gz <id> testcontainer test.txt

# push them to the storage nodes
# sudo scp openstack@192.168.2.1:/etc/swift/*.gz /etc/swift
# sudo scp openstack@192.168.2.1:/etc/swift/*builder* /etc/swift

# wait... wait... wait...

# watch that it moved
ssh <node> "ls -lah /srv/node/sda6/objects/<.....>"
